import axios from 'axios'
import { Message } from 'element-ui'
import store from '@/store'

const request = axios.create({
  baseURL: 'http://big-event-vue-api-t.itheima.net',
  timeout: 8000
})

// 添加请求拦截器
request.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么

  if (config.data && config.url !== '/my/article/add' && config.url !== '/my/article/info') {
    config.data = JSON.stringify(config.data)
    config.headers['content-type'] = 'application/json'
  }
  const token = store.state.user.token
  if (token) {
    config.headers.Authorization = token
  }
  return config
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error)
})

// 添加响应拦截器
request.interceptors.response.use(function (response) {
  // 对响应数据做点什么
  return response.data
}, function (error) {
  if (error.response) {
    Message.error(error.response.data.message)
  }
  // 对响应错误做点什么
  return Promise.reject(error)
})

export default request
